g_signal_handlers_disconnect_by_func (priv->surface, surface_event, widget);
g_signal_handlers_disconnect_by_func (priv->surface, surface_moved_to_rect, widget);
gdk_surface_set_widget (priv->surface, NULL);
-
+ gdk_surface_destroy (priv->surface);
g_clear_object (&priv->surface);
}
priv->surface_transform_changed_cb = 0;
GTK_WIDGET_CLASS (gtk_popover_parent_class)->unmap (widget);
-
gdk_surface_hide (priv->surface);
child = gtk_bin_get_child (GTK_BIN (widget));
update_cursor_on_state_change (widget);
- if (!GTK_IS_NATIVE (widget))
- gtk_widget_queue_draw (widget);
+ gtk_widget_queue_draw (widget);
gtk_widget_pop_verify_invariants (widget);
}
priv->draw_needed = TRUE;
g_clear_pointer (&priv->render_node, gsk_render_node_unref);
- if (GTK_IS_NATIVE (widget) &&
- _gtk_widget_get_realized (widget))
- gdk_surface_queue_expose (gtk_widget_get_surface (widget));
+ if (GTK_IS_NATIVE (widget) && _gtk_widget_get_realized (widget))
+ gdk_surface_queue_expose (gtk_native_get_surface (GTK_NATIVE (widget)));
}
}
if (priv->realized)
{
- /* We use gtk_widget_get_root() here to make it explicit that
- * the frame clock is a property of the toplevel that a widget
- * is anchored to; gdk_surface_get_toplevel() will go up the
- * hierarchy anyways, but should squash any funny business with
- * reparenting windows and widgets.
- */
- GtkRoot *root = _gtk_widget_get_root (widget);
- GdkSurface *surface = _gtk_widget_get_surface (GTK_WIDGET (root));
- g_assert (surface != NULL);
-
- return gdk_surface_get_frame_clock (surface);
+ return gdk_surface_get_frame_clock (priv->surface);
}
else
{
GtkWidget *p;
priv->mapped = TRUE;
- if (GTK_IS_NATIVE (widget))
- gdk_surface_show (priv->surface);
-
for (p = gtk_widget_get_first_child (widget);
p != NULL;
p = gtk_widget_get_next_sibling (p))
GtkWidget *child;
priv->mapped = FALSE;
- if (GTK_IS_NATIVE (widget))
- gdk_surface_hide (priv->surface);
-
for (child = gtk_widget_get_first_child (widget);
child != NULL;
child = gtk_widget_get_next_sibling (child))
if (GTK_IS_NATIVE (widget))
{
g_assert (priv->surface != NULL);
+ priv->surface = gtk_native_get_surface (GTK_NATIVE (widget));
+ g_object_ref (priv->surface);
}
else
{
priv->realized = FALSE;
- if (GTK_IS_NATIVE (widget))
- {
- gdk_surface_destroy (priv->surface);
- priv->surface = NULL;
- }
- else
- {
- g_object_unref (priv->surface);
- priv->surface = NULL;
- }
+ g_clear_object (&priv->surface);
}
void
gtk_widget_get_child_visible (priv->title_box))
gtk_widget_map (priv->title_box);
- surface = _gtk_widget_get_surface (widget);
+ surface = priv->surface;
if (priv->maximize_initially)
gdk_surface_maximize (surface);
return;
}
- surface = _gtk_widget_get_surface (widget);
+ surface = priv->surface;
GTK_WIDGET_CLASS (gtk_window_parent_class)->unmap (widget);
gdk_surface_hide (surface);
gint *width,
gint *height)
{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
GtkWidget *widget;
- GdkDisplay *display;
GdkSurface *surface;
+ GdkDisplay *display;
GdkMonitor *monitor;
GdkRectangle workarea;
int minimum, natural;
widget = GTK_WIDGET (window);
display = gtk_widget_get_display (widget);
- surface = _gtk_widget_get_surface (widget);
+ surface = priv->surface;
if (surface)
monitor = gdk_display_get_monitor_at_surface (display, surface);
gsk_renderer_unrealize (priv->renderer);
g_clear_object (&priv->renderer);
- surface = _gtk_widget_get_surface (widget);
+ surface = priv->surface;
g_signal_handlers_disconnect_by_func (surface, surface_state_changed, widget);
g_signal_handlers_disconnect_by_func (surface, surface_size_changed, widget);
g_signal_handlers_disconnect_by_func (surface, surface_render, widget);
g_signal_handlers_disconnect_by_func (surface, surface_event, widget);
gdk_surface_set_widget (surface, NULL);
+ gdk_surface_destroy (surface);
+ g_clear_object (&priv->surface);
GTK_WIDGET_CLASS (gtk_window_parent_class)->unrealize (widget);